tools/gtraceview: fix SIGFPE
authorKeir Fraser <keir.fraser@citrix.com>
Fri, 29 Jan 2010 08:59:46 +0000 (08:59 +0000)
committerKeir Fraser <keir.fraser@citrix.com>
Fri, 29 Jan 2010 08:59:46 +0000 (08:59 +0000)
If there are 0 or 1 valid record in xentrace file,
SIGFPE will occur. Fix it.

Signed-off-by: Yu Zhiguo <yuzg@cn.fujitsu.com>
tools/misc/gtraceview.c

index 52b7ae2846099304b8f37fd34e6163be63a45d40..3bfedad6542d39e8d2f88bd7353587e2d61b6ae1 100644 (file)
@@ -209,6 +209,11 @@ int main(int argc, char *argv[])
     if (load_file(fname))
         exit(EXIT_FAILURE);
 
+    if (!data_cur) {
+        fprintf(stderr, "file %s doesn't contain any valid record\n", fname);
+        exit(EXIT_FAILURE);
+    }
+
     if (mode_init())
         exit(EXIT_FAILURE);
 
@@ -939,14 +944,15 @@ int time_mode_rebuild(uint64_t start_time, uint64_t time_scale)
     struct cpu cur_state[MAX_CPU_NR];
     uint64_t tsc = start_time;
     struct state *state;
-    uint64_t number, temp;
+    uint64_t number, temp = 0;
     int state_cur = 0;
 
     for (i = 0; i < max_cpu_num; i++)
         cur_state[i].flag = FLAG_UNKNOWN;
 
     /* allocate spaces, it may be huge... */
-    temp = (data[data_cur-1].tsc - start_time)/time_scale;
+    if (time_scale)
+        temp = (data[data_cur-1].tsc - start_time)/time_scale;
     number = 10000UL;
     if (temp < number)
         number = temp;